<template>
  <div class="app-container">
    <el-form
      :model="queryParams"
      ref="queryForm"
      v-show="showSearch"
      :inline="true"
    >
      <el-form-item label="用户昵称" prop="userName">
        <el-input
          v-model="queryParams.nickName"
          placeholder="请输入用户昵称"
          clearable
          size="small"
          style="width: 240px"
          @keyup.enter.native="handleQuery"
        />
      </el-form-item>
      <el-form-item label="手机号码" prop="phonenumber">
        <el-input
          v-model="queryParams.phonenumber"
          placeholder="请输入手机号码"
          clearable
          size="small"
          style="width: 240px"
          @keyup.enter.native="handleQuery"
        />
      </el-form-item>
      <el-form-item>
        <el-button
          type="primary"
          icon="el-icon-search"
          size="mini"
          @click="handleQuery"
          >搜索</el-button
        >
        <el-button icon="el-icon-refresh" size="mini" @click="resetQuery"
          >重置</el-button
        >
      </el-form-item>
    </el-form>

    <el-row :gutter="10" class="mb8">
      <el-col :span="1.5">
        <el-button
          type="primary"
          plain
          icon="el-icon-plus"
          size="mini"
          @click="openSelectUser"
          v-hasPermi="['system:zld:add']"
          >添加用户</el-button
        >
      </el-col>
      <el-col :span="1.5">
        <el-button
          type="danger"
          plain
          icon="el-icon-circle-close"
          size="mini"
          :disabled="multiple"
          @click="cancelAuthUserAll"
          v-hasPermi="['system:zld:remove']"
        >
          批量取消授权
        </el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button
          type="warning"
          plain
          icon="el-icon-close"
          size="mini"
          @click="handleClose"
          >关闭</el-button
        >
      </el-col>
      <right-toolbar
        :showSearch.sync="showSearch"
        @queryTable="getList"
      ></right-toolbar>
    </el-row>

    <el-table
      v-loading="loading"
      :data="userList"
      @selection-change="handleSelectionChange"
      height="600px"
      @scrollBottom="scrollPaging"
    >
      <el-table-column type="selection" width="55" align="center" />
      <el-table-column
        label="用户名称"
        prop="userName"
        :show-overflow-tooltip="true"
      />
      <el-table-column
        label="用户昵称"
        prop="nickName"
        :show-overflow-tooltip="true"
      />
      <el-table-column
        label="物理卡号"
        prop="userPhysicalCard"
        :show-overflow-tooltip="true"
      />
      <el-table-column
        label="手机"
        prop="phonenumber"
        :show-overflow-tooltip="true"
      />
      <el-table-column
        label="部门"
        prop="dept.deptName"
        :show-overflow-tooltip="true"
      />
      <el-table-column label="状态" align="center" prop="status">
        <template #default="scope">
          <dict-tag :options="statusOptions" :value="scope.row.status" />
        </template>
      </el-table-column>
      <el-table-column
        label="创建时间"
        align="center"
        prop="createTime"
        width="180"
      >
        <template #default="scope">
          <span>{{ parseTime(scope.row.createTime) }}</span>
        </template>
      </el-table-column>
      <el-table-column
        label="操作"
        align="center"
        class-name="small-padding fixed-width"
      >
        <template #default="scope">
          <el-button
            size="mini"
            type="text"
            icon="el-icon-circle-close"
            @click="cancelAuthUser(scope.row)"
            v-hasPermi="['system:zld:remove']"
          >
            取消授权
          </el-button>
        </template>
      </el-table-column>
    </el-table>

    <!-- <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize" @pagination="getList" /> -->
    <select-user
      ref="select"
      :zldId="queryParams.zldId"
      :zldZldm="queryParams.zldZldm"
      @ok="handleQuery"
    />
  </div>
</template>

<script>
import {
  allocatedUserList,
  authUserCancel,
  authUserCancelAll,
} from "@/api/system/zld";
import selectUser from "./selectUserZld";
const scrollPaging = (() => {
  let total = 0;
  let data = [];
  let pageSize = 30;
  let pageNum = 1;
  let loading = false;

  return function (queryParams, req) {
    pageSize = queryParams.pageSize || 20;
    if (queryParams.pageNum <= 1) {
      data = [];
      pageNum = 1;
    }
    queryParams.pageNum = pageNum;
    if (
      !total ||
      queryParams.pageNum <= Math.ceil(total / queryParams.pageSize)
    ) {
      if (!loading) {
        loading = true;
        return req(queryParams).then((response) => {
          loading = false;
          data = data.concat(response.rows);
          total = response.total;
          response.data_paging = data;
          pageNum++;
          queryParams.pageNum++;
          return response;
        });
      }
    }
    return Promise.resolve({ data_paging: data });
  };
})();

export default {
  name: "AuthUser",
  components: { selectUser },
  data() {
    return {
      // 遮罩层
      loading: true,
      // 选中用户组
      userIds: [],
      // 非多个禁用
      multiple: true,
      // 显示搜索条件
      showSearch: true,
      // 总条数
      total: 0,
      // 用户表格数据
      userList: [],
      // 状态数据字典
      statusOptions: [],
      // 查询参数
      queryParams: {
        pageNum: 1,
        pageSize: 30,
        zldId: undefined,
        userName: undefined,
        phonenumber: undefined,
        zldZldm: null,
        zldPhysicalCard: null,
      },
    };
  },
  created() {
    // const data = this.$route.params && this.$route.params.zldId;
    const data = this.$route.params;
    if (data) {
      this.queryParams.zldId = data.zldId;
      this.queryParams.zldZldm = data.zldZldm;
      this.getDicts("sys_normal_disable").then((response) => {
        this.statusOptions = response.data;
      });
      this.getList();
    }
  },
  methods: {
    /** 查询授权用户列表 */
    getList() {
      this.loading = true;
      allocatedUserList(this.queryParams).then((response) => {
        this.userList = response.rows;
        this.total = response.total;
        this.loading = false;
      });
    },
    // 通用滚动分页
    scrollPaging() {
      this.loading = true;
      scrollPaging(this.queryParams, allocatedUserList).then((res) => {
        this.userList = res.data_paging;
        this.loading = false;
      });
    },
    // 返回按钮
    handleClose() {
      this.$store.dispatch("tagsView/delView", this.$route);
      this.$router.push({ path: "/system/zld" });
    },
    /** 搜索按钮操作 */
    handleQuery() {
      this.queryParams.pageNum = 1;
      this.getList();
    },
    /** 重置按钮操作 */
    resetQuery() {
      this.resetForm("queryForm");
      this.handleQuery();
    },
    // 多选框选中数据
    handleSelectionChange(selection) {
      this.userIds = selection.map((item) => item.userId);
      this.multiple = !selection.length;
    },
    /** 打开授权用户表弹窗 */
    openSelectUser() {
      this.$refs.select.show();
    },
    /** 取消授权按钮操作 */
    cancelAuthUser(row) {
      const zldId = this.queryParams.zldId;
      this.$confirm('确认要取消该用户"' + row.userName + '"角色吗？', "警告", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning",
      })
        .then(function () {
          return authUserCancel({ userId: row.userId, zldId: zldId });
        })
        .then(() => {
          this.getList();
          this.msgSuccess("取消授权成功");
        })
        .catch(() => {});
    },
    /** 批量取消授权按钮操作 */
    cancelAuthUserAll(row) {
      const zldId = this.queryParams.zldId;
      const userIds = this.userIds.join(",");
      this.$confirm("是否取消选中用户授权数据项?", "警告", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning",
      })
        .then(() => {
          return authUserCancelAll({ zldId: zldId, userIds: userIds });
        })
        .then(() => {
          this.getList();
          this.msgSuccess("取消授权成功");
        })
        .catch(() => {});
    },
  },
};
</script>
